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Response to Amendment 



1. 



This action is in response to the Amendment received on Feb 02, 2006. 



2. 



Claims previously cancelled by the applicant: 6 and 13 



3. 



Claims previously amended by the applicant: 1, 8, 16, 21, 26, 31, and 36. 



4. 



Claims pending in the application: 1-5, 7-12, and 14-40. 



Response to Arguments 



5. Applicant's arguments with respect to claims have been considered but they are not 
persuasive. 

In the remarks, the applicant has argued that: 

In genera), Chen, Zucker and Huangs do not disclose or suggest method of producing a 
binary code file where the binary code file includes binary code instruction and compiler 
annotation where the compiler annotation is an ELF section, as substantially required by each of 
the independent claims. The ELF header 64 of Zucker neither teaches nor suggests the claimed 
binary code file having both biliary code instructions and compiler annotation which is an ELF 
section: Additionally, "debugging data" as set forth by Huangs neither teaches nor suggests the 
claimed compiler annotation. 

Examiner's response: 

In response to Applicants arguments, it is noted that the rejection clearly points out where 
Chen, Zucker and Huangs teach the claimed features and why it would have been obvious to 
combine their teachings (see rejection below). Specifically, the rejection points out where the 
limitations of the claim are taught by the references Chen, Zucker and Huangs. In addition, 
Huangs discloses the limitation compiler annotation is an ELF section as being debugging data. 
Because compiler annotations are nothing but the information useful for binary translators as 
indicated by the Applicants in the Remarks, page 9. Further, Applicant presented the similar 
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arguments for claim 8, 16, 21, 26, 31, and 36 are given the same reasoning as above. Therefore, 
the rejection is proper and maintained herein. 



6. THIS ACTION IS MADE FINAL. Applicant is reminded of the extension of time 
policy as set forth in 37 CFR 1.136(a). 

7. A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within TWO 
MONTHS of the mailing date of this final action and the advisory action is not mailed until after 
the end of the THREE-MONTH shortened statutory period, then the shortened statutory period 
will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 

CFR 1.136(a) will be calculated from the mailing date of the advisory action. In no event, 
however, will the statutory period for reply expire later than SIX MONTHS from the mailing 
date of this final action. 



Claim Rejections - 35 USC §103 
8. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in section 102 of this 
title, if the differences between the subject matter sought to be patented and the prior art are such that the subject matter as a 
whole would have been obvious at the time the invention was made to a person having ordinary skill in the art to which said 
subject matter pertains. Patentability shall not be negatived by the manner in which the invention was made. 



9. Claims 1, 2, 3, 5, 8, 9, 10, 12, 16, 17, 18, 20-23 25-28, and 30-40 are rejected under 35 



U.S.C. 103(a) as being unpatentable over US Patent No. 6,625,807 to Chen (hereinafter called 
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Chen) in view of US Patent No. 5,991,871 to Zucker (hereinafter called Zucker) and further in 
view of the document published on the Internet 

r www.cs.ucdavis.edu/~haungs/paper/nodelO.htmn on 9/21/1998 by Michael L. Haungs 
(hereinafter called Haungs). 
Per claims 1, 8 and 16: 
Chen disclose: 

- A method of producing a binary code file (col. 6, lines 40-41 "The original binary 
program code... generated by the system compiler") comprising: 

- compiling a plurality of source code instructions (col. 6, lines 25-26 "The original source 
code... is input into the system compiler"); and 

- outputting a plurality of binary code instructions (col. 5, lines 47-49 "transforms the code 
into equivalent machine code in a form of a relocatable. . . or directly executable object 
code") and compiler annotation (col. 6, lines 34-38 "The register usage annotator 70 
generates bit vector annotation. . . of the system compiler 60"). 

Chen does not explicitly disclose the plurality of binary code instructions being executable by a 
processor of a computer system, the plurality of binary code instructions are an executable and 
linking format (ELF) binary code file. 

However, Zucker discloses in an analogous computer system the plurality of binary code 
instructions being executable by a processor of a computer system, the plurality of binary code 
instructions are an executable and linking format (ELF) binary code file (col. 8, lines 28-39 
"object program 60 comprises an ELF header 64 that specifies the number and sizes of the 
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sections of the program 60.. . the operating system 48. A section header table 66 is also provided, 
including information required to locate all of the sections of the file 60. . . data of the program 
are provided... dynamic linking information... linker" also, FIG. 4 and related discussion). 

Therefore, it would have been obvious to a person of ordinary skill in the art at the time the 
invention was made to incorporate the method of the plurality of binary code instructions being 
executable by a processor of a computer system, the plurality of binary code instructions are an 
executable and linking format (ELF) binary code file and the compiler annotation is an ELF 
section as taught by Zucker into the method of generating binary code file as taught by Chen. 
The modification would be obvious because of one of ordinary skill in the art would be 
motivated use the ELF format file to provide an application binary interface and memory 
mapping system that can efficiently acquire that absolute address, manage linkage, support 
variable augmented functions, and avoid high overhead for page table entry deletion process as 
taught by Zucker (col. 4, lines 10-20). 

Neither Chen nor Zucker disclose the compiler annotation is an ELF section. 

However, Haungs discloses in an analogous computer system the compiler annotation is 
an ELF section (page 1 of 1, ELF Sections "There are a number of types of sections described by 
entries in the section header table. Sections can hold executable code, data, dynamic linking 
information, debugging data (compiler annotations), symbol tables, relocation information, 
comments, string tables, and notes...") (emphasis added). 

Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to incorporate the method of the compiler annotation is an ELF section 
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as taught by Haungs into the method of generating binary code file as taught by the combination 
system of Chen and Zucker. Also, the ELF sections could be many types, and has been known 
and was originally developed by Unix System Laboratories. The modification would be obvious 
because of one of ordinary skill in the art would be motivated have the compiler annotation is an 
ELF section to provide more flexibility to the operating system as suggested by Haungs (page 1 
of 2, 1 st paragraph). 

Per claims 2, 9 and 17: 

The rejection of claim 1 is incorporated, and further, Chen disclose: 

- wherein the compiler annotation enables binary translation to be performed on the 
plurality of binary code instructions using a non-heuristic approach (col. 6, lines 17-18 
"The translation process. . . then translates the code into the translated binary objects 
code"). 

Per claims 3, 10 and 18: 

The rejection of claim 1 is incorporated, and further, Chen disclose: 

- wherein the compiler annotation describes functional characteristics of the plurality of 
binary code instructions (col. 6, lines 54-58 "the parser processes the sequence of tokens 
and produces an intermediate level representation, such as a parse tree or sequential 
intermediate code, and symbol table that records the identifiers used in the program 
and/or attributes"). 
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Per claims 5, 12 and 20: 

The rejection of claim 1 is incorporated, and further, Chen disclose: 

- examining the plurality of source code instructions (col. 6, lines 25-26 "The original 
source code... is input into the system compiler"); 

- reorganizing one or more of the plurality of source code instructions (col. 5, lines 13-18 
"The analyzer... checking a program for validity... process takes... intermediate code 
generated in the parsing. . . symbol table. . . determines whether or not the program 
satisfies the properties required by the source language"); 

- translating the plurality of source code instructions into the plurality of binary code 
instructions (col. 5, lines 47-49 "transforms the code into equivalent machine code in a 
form of a relocatable. . . or directly executable object code"); 

- reorganizing one or more of the plurality of binary code instructions (col. 6, lines 4-5 
"Once the program. . . compiled. . . liked to interconnected the parts of the program. . . 
needed library routines"); and 

- tracking and recording functional characteristics of the plurality of source code 
instructions and of the plurality of binary code instructions (col. 6, lines 7-8 "The 
program.. . routines are read and then relocated by a loader to produce a machine- 
executable image in memory"). 
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Claims 21-23 is the apparatus claim corresponding to method claims 1, 2, and 3 respectively, and 
rejected under the same rational set forth in connection with the rejection of claims 1, 2, and 3 
respectively, above. 

Claim 25, 26 is the apparatus claim corresponding to method claims 1, 5 and rejected under the 
same rational set forth in connection with the rejection of claims 1, 5 above. 
Claims 27, 28 and 30 is the apparatus claim corresponding to method claims 2, 3, and 5 
respectively, and rejected under the same rational set forth in connection with the rejection of 
claims 2, 3, and 5 respectively, above. 

Claim 28 is the apparatus claim corresponding to method claim 3 and rejected under the same 
rational set forth in connection with the rejection of claim 3 above. 

Claim 31-35 are the computer product claim corresponding to method claims 1-5 respectively, 
and rejected under the same rational set forth in connection with the rejection of claims 1-5 
respectively, above. 

Claim 36-40 are the computer product claim corresponding to method claims 1-5 respectively, 
and rejected under the same rational set forth in connection with the rejection of claims 1-5 
respectively, above. 

10. Claims 4, 7, 1 1, 14, 15, 19, 24 and 29 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Chen, Zucker and Haungs in view of US Patent No. 6,353,925 to Stata et al. 
(hereinafter called Stata). 
Per claims 4, 7, 11, 14, 15 and 19: 
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The rejection of claim 1, 8, 16 is incorporated, and further, neither Chen nor Zucker nor Haungs 
explicitly disclose the compiler annotation comprises one or more records selected from a 
module identification (ED), a function ID, a split function ED, a jump table ED, a function 
pointer initialization ID, a function address assignment ID, an offset expression ID, a data in the 
text section ED, a volatile load ID, and an untouchable region ID. 

However, Stata discloses in an analogous computer system the compiler annotation 
comprises one or more records selected from a module identification (ED), a function ID, a split 
function ID, a jump table ID, a function pointer initialization ID, a function address assignment 
ID, an offset expression ID, a data in the text section ED, a volatile load ID, and an untouchable 
region ED (col. 6, lines 40-42 "Each tool. . . have a set of annotations. . . recognizes and 
support. . . annotations are placed in the source file along with the programming-language 
statements" and (col. 6, lines 64-66 "the annotation language... say any comment whose first 
character is the character "@" is an annotation"). 

Therefore, it would have been obvious to a person of ordinary skill in the art at the time 
the invention was made to incorporate the method of selecting or having annotations within the 
code as taught by Stata into the method of generating the binary code files as taught by the 
combination system of Chen, Zucker and Haungs. The modification would be obvious because 
of one of ordinary skill in the art would be motivated to use annotations within the code to 
provide less modification of the code if one need to transfer from one system to another as 
suggested by Stata (col. 1 and 2, lines 64-67 and 1-6). 
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Claim 24 is the apparatus claim corresponding to method claim 4 and rejected under the same 
rational set forth in connection with the rejection of claim 4 above. 

Claim 29 is the apparatus claim corresponding to method claim 4 and rejected under the same 
rational set forth in connection with the rejection of claim 4 above. 



examiner should be directed to Satish S. Rampuria whose telephone number is (571) 272-3732. 
The examiner can normally be reached on 8:30 am to 5:00 pm Monday to Friday except every 
other Friday and federal holidays. Any inquiry of a general nature or relating to the status of this 
application should be directed to the TC 2100 Group receptionist: 571-272-2100 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Wei Y. Zhen can be reached on (571) 272-3708. The fax phone number for the 
organization where this application or proceeding is assigned is 703-872-9306. 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). 



Conclusion 



1 1 . Any inquiry concerning this communication or earlier communications from the 



Satish S. Rampuria 

Patent Examiner/Software Engineer 

Art Unit 2191 




